Volunteer computing
Volunteer computing is a type of distributed computing in which computer owners donate their computing resources (such as processing power and storage) to one or more "projects".
History
The first volunteer computing project was the Great Internet Mersenne Prime Search, which was started in January 1996.[1] It was followed in 1997 by distributed.net. In 1997 and 1998 several academic research projects developed Java-based systems for volunteer computing; examples include Bayanihan,[2] Popcorn,[3] Superweb,[4] and Charlotte.[5]. Another similar concept is Sideband computing which let a user to share his computing power while he is online.
The term "volunteer computing" was coined by Luis F. G. Sarmenta, the developer of Bayanihan. It is also appealing for global efforts on social responsibility, or Corporate Social Responsibility as reported in a Harvard Business Review [6] or used in the Responsible IT forum.[7]
In 1999 the SETI@home and Folding@home projects were launched. These projects received considerable media coverage, and each one attracted several hundred thousand volunteers.
Between 1998 and 2002, several companies were formed with business models involving volunteer computing. Examples include Popular Power, Porivo, Entropia, and United Devices.
In 2002, the Berkeley Open Infrastructure for Network Computing (BOINC) opensource project was founded, and became the software running the largest public computing grid (World Community Grid) in 2007. [8]
Middleware for volunteer computing
The client software of the early volunteer computing projects consisted of a single program that combined the scientific computation and the distributed computing infrastructure. This monolithic architecture was inflexible; for example, it was difficult to deploy new application versions.
More recently, volunteer computing has moved to middleware systems that provide a distributed computing infrastructure independently of the scientific computation. Examples include:
Most of these systems have the same basic structure: a client program runs on the volunteer's computer. It periodically contacts project-operated servers over the Internet, requesting jobs and reporting the results of completed jobs. This "pull" model is necessary because many volunteer computers are behind firewalls that do not allow incoming connections. The system keeps track of each user's "credit", a numerical measure of how much work that user's computers have done for the project.
Volunteer computing systems must deal with several problematic aspects of the volunteered computers: their heterogeneity, their churn (that is, the arrival and departure of hosts), their sporadic availability, and the need to not interfere with their performance during regular use.
In addition, volunteer computing systems must deal with several related problems related to correctness:
- Volunteers are unaccountable and essentially anonymous.
- Some volunteer computers (especially those that are overclocked) occasionally malfunction and return incorrect results.
- Some volunteers intentionally return incorrect results or claim excessive credit for results.
One common approach to these problems is "replicated computing", in which each job is performed on at least two computers. The results (and the corresponding credit) are accepted only if they agree sufficiently.
Costs for volunteer computing participants
- Increased power consumption. A CPU that is idle generally has lower power consumption than when it is active. The desire to participate may also cause the volunteer to leave the PC on overnight, or to disable power-saving features like suspend. Additionally, if adequate cooling is not in place, this constant load on the volunteer's CPU can cause it to overheat.
- Decreased performance of the PC. If the volunteer computing application attempts to run while the computer is in use, it will impact performance of the PC. This is due to increased CPU contention, CPU cache contention, disk I/O contention, and network I/O contention. If RAM is a limitation, increased disk cache misses and/or increased paging can result. Volunteer computing applications typically execute at a lower CPU scheduling priority, which helps to alleviate CPU contention.[9]
These effects may or may not be noticeable, and even if they are noticeable, the volunteer might choose to continue participating. However the increased power consumption can be remedied to some extent by setting the option of desired processor usage percent, that is available e.g. in BOINC client.
References
- ^ "GIMPS History". http://mersenne.org/various/history.php.
- ^ Sarmenta, L.F.G. "Bayanihan: Web-Based Volunteer Computing Using Java". Lecture Notes in Computer Science 1368, Springer-Verlag, 1998. pp. 444-461. Proc. of the 2nd International Conference on World-Wide Computing and its Applications (WWCA'98), Tsukuba, Japan, March 3-4, 1998
- ^ Regev, O; Nisan, N (October 25 - 28, 1998). "The POPCORN market~Wan online market for computational resources". Proceedings of the First international Conference on information and Computation Economies. Charleston, South Carolina, United States: ACM Press, New York, NY. pp. 148–157.
- ^ Alexandrov, A.D.; M. Ibel, K.E. Schauser, K.E. Scheiman (1996). "SuperWeb: Research issues in Java-Based Global Computing". Proceedings of the Workshop on Java for High performance Scientific and Engineering Computing Simulation and Modelling. New York: Syracuse University.
- ^ A.; Karaul, M., Kedem, Z., Wyckoff, P. (Sept 1996). "Charlotte: Metacomputing on the Web". Proceedings of the 9th International Conference on Parallel and Distributed Computing Systems. http://citeseer.ist.psu.edu/article/baratloo96charlotte.html.
- ^ Porter, Michael; Mark Kramer. "The Link Between Competitive Advantage and Corporate Social Responsibility". Harvard Business Review. http://harvardbusinessonline.hbsp.harvard.edu/email/pdfs/Porter_Dec_2006.pdf.
- ^ "ResponsI.TK". Responsible IT forum. http://www.responsI.tk.
- ^ BOINC Migration Announcement
- ^ "Measuring Folding@Home's performance impact". http://techreport.com/articles.x/4341/1.
See also
External links
|
|
Current projects |
|
|
Beta projects |
|
|
Alpha projects |
AlmereGrid Boinc Grid · Biochemical Library · CAS@home · Chess960@home · Correlizer · DistributedDataMining · DNA@Home · DrugDiscovery@Home · eOn · Goldbach's Conjecture Project · Hydrogen@Home · Magnetism@home · Mersenne@home · Moo! Wrapper · NFS@Home · NumberFields@home · Pirates@home · Primaboinca · QuantumFIRE · RADIOACTIVE@HOME · RALPH@home · Renderfarm.fi · RSA Lattice Siever · SAT@home · SLinCA@Home · Sudoku@vtaiwan · Surveill@Home · Virtual Prairie · Volpex · VTU@Home · WUProp@Home · YAFU
|
|
Future projects |
|
|
Tools and technology |
|
|
Ended / Non-active projects |
|
|